<?php
/**
 * User: LRZ
 * Date: 2020/2/22
 * Time: 15:15
 */

/**
 *  976.三角形的最大周长
 *
 *  标签：排序、数学
 *
 *  给定由一些正数（代表长度）组成的数组 A，返回由其中三个长度组成的、面积不为零的三角形的最大周长。
 *  如果不能形成任何面积不为零的三角形，返回 0。
 *
 *  示例 1：
 *      输入：[2,1,2]
 *      输出：5
 *
 *  示例 2：
 *      输入：[1,2,1]
 *      输出：0
 *
 *  示例 3：
 *      输入：[3,2,3,4]
 *      输出：10
 *
 *  示例 4：
 *      输入：[3,6,2,3]
 *      输出：8
 *   
 *  提示：
 *      3 <= A.length <= 10000
 *      1 <= A[i] <= 10^6
 *
 *  来源：力扣（LeetCode）
 *  链接：https://leetcode-cn.com/problems/largest-perimeter-triangle
 *  著作权归领扣网络所有。商业转载请联系官方授权，非商业转载请注明出处。
 */

$start = microtime(true);

$A   = [2, 1, 1];
$res = largestPerimeter($A);

$end = microtime(true);
print_r($res);
printf(' total run: %.2f s<br>' . 'memory usage: %.2f M<br> ', $end - $start, memory_get_usage() / 1024 / 1024);

function largestPerimeter($A)
{
    sort($A);
    $size = count($A);
    for ($i = $size - 3; $i >= 0; $i--) {
        if ($A[$i] + $A[$i + 1] > $A[$i + 2]) {
            return $A[$i] + $A[$i + 1] + $A[$i + 2];
        }
    }
    return 0;
}